import axios from "axios";
import "element-plus/theme-chalk/el-message.css";
import {useUserStore} from "@/stores/user"
import { ElMessage } from "element-plus";
import router from "@/router"; 
const httpInstance = axios.create({
    baseURL: 'http://pcapi-xiaotuxian-front-devtest.itheima.net',
    timeout: 5000
})

//axios请求拦截器
httpInstance.interceptors.request.use(config => {
    //1.从pinia获取token数据
    const userStore = useUserStore()
   
    //2.按照后端的要求拼接token数据
     const token = userStore.userInfo.token
    if(token){
        config.headers.Authorization = `Bearer ${token}`
    }
    return config
}, e => Promise.reject(e))
//axios响应式拦截器
httpInstance.interceptors.response.use(res => res.data, e => {
    ElMessage.warning(e.response.data.message)
    const userStore = useUserStore()
    //token401拦截处理
    if(e.response.status === 401){
        userStore.clearUserInfo()
        router.push('/login')
    }
    return Promise.reject(e)
})

export default httpInstance